package com.hxm.demo.leetcode;

import java.util.Scanner;

/**
 * @author huangxiaoming
 * @description
 * @date 2022/6/16 0:31
 */
public class Test37 {

    /**
     * 描述
     * 有一种兔子，从出生后第3个月起每个月都生一只兔子，小兔子长到第三个月后每个月又生一只兔子。
     * 例子：假设一只兔子第3个月出生，那么它第5个月开始会每个月生一只兔子。
     * 一月的时候有一只兔子，假如兔子都不死，问第n个月的兔子总数为多少？
     * 数据范围：输入满足 1 \le n \le 31 \ 1≤n≤31
     * 输入描述：
     * 输入一个int型整数表示第n个月
     * <p>
     * 输出描述：
     * 输出对应的兔子总数
     *
     * @param args
     */
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        // 注意 hasNext 和 hasNextLine 的区别
        while (in.hasNextInt()) { // 注意 while 处理多个 case
            int n = in.nextInt();

            if (n == 1 || n == 2) {
                System.out.println(1);
            }
            int pre1 = 1;
            int pre2 = 1;
            for (int i = 3; i <= n; i++) {
                int cur = pre1 + pre2;
                pre1 = pre2;
                pre2 = cur;
            }
            System.out.println(pre2);
        }
    }
}
